home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
Wayzata's Best of Shareware PC/Windows 1
/
Wayzata's Best of Shareware for PC-Windows - Release 1 - Wayzata Technology (1993).iso
/
mac
/
DOS
/
GRAPHICS
/
RAYSH386
/
STATS.C
< prev
next >
Wrap
C/C++ Source or Header
|
1991-07-18
|
4KB
|
143 lines
/*
* stats.c
*
* Copyright (C) 1989, 1991, Craig E. Kolb
* All rights reserved.
*
* This software may be freely copied, modified, and redistributed
* provided that this copyright notice is preserved on all copies.
*
* You may not distribute this software, in whole or in part, as part of
* any commercial product without the express consent of the authors.
*
* There is no warranty or other guarantee of fitness of this software
* for any purpose. It is provided solely "as is".
*
* $Id: stats.c,v 4.0 91/07/17 14:47:41 kolb Exp Locker: kolb $
*
* $Log: stats.c,v $
* Revision 4.0 91/07/17 14:47:41 kolb
* Initial version.
*
*/
#include <ctype.h>
#include "rayshade.h"
#include "options.h"
#include "stats.h"
RSStats Stats; /* Statistical information */
Geom *GeomRep = NULL; /* Linked list of object representatives */
static void PrintGeomStats();
void
StatsPrint()
{
extern void PrintMemoryStats();
unsigned long TotalRays;
#ifndef LINDA
RSGetCpuTime(&Stats.Utime, &Stats.Stime);
#endif
ShadowStats(&Stats.ShadowRays, &Stats.ShadowHits,
&Stats.CacheHits, &Stats.CacheMisses);
IntersectStats(&Stats.BVTests);
TotalRays = Stats.EyeRays + Stats.ShadowRays + Stats.ReflectRays
+ Stats.RefractRays;
Stats.ShadowHits += Stats.CacheHits;
Stats.HitRays += Stats.ShadowHits;
#ifdef LINDA
fprintf(Stats.fstats,"Workers:\t\t\t%d\n",Options.workers);
#endif
fprintf(Stats.fstats,"Eye rays:\t\t\t%lu\n", Stats.EyeRays);
fprintf(Stats.fstats,"Shadow rays:\t\t\t%lu\n",Stats.ShadowRays);
fprintf(Stats.fstats,"Reflected rays:\t\t\t%lu\n",Stats.ReflectRays);
fprintf(Stats.fstats,"Refracted rays:\t\t\t%lu\n",Stats.RefractRays);
fprintf(Stats.fstats,"Total rays:\t\t\t%lu\n", TotalRays);
if (TotalRays != 0)
fprintf(Stats.fstats,"Intersecting rays:\t\t%lu (%3.3f%%)\n",
Stats.HitRays,
100. * (float)Stats.HitRays / (float)TotalRays);
if (Stats.ShadowRays != 0) {
if (Options.cache)
fprintf(Stats.fstats,
"Shadow cache hits:\t\t%lu (%lu misses)\n",
Stats.CacheHits, Stats.CacheMisses);
fprintf(Stats.fstats,"Total shadow hits:\t\t%lu (%3.3f%%)\n",
Stats.ShadowHits, 100.*(float)Stats.ShadowHits /
(float)Stats.ShadowRays);
}
fprintf(Stats.fstats,"Supersampled pixels:\t\t%lu\n",
Stats.SuperSampled);
fprintf(Stats.fstats,"B.V. intersection tests:\t%lu\n",Stats.BVTests);
PrintGeomStats();
#ifdef LINDA
fprintf(Stats.fstats,"Average CPU time/processor:\t");
#else
fprintf(Stats.fstats,"Total CPU time (sec):\t\t");
#endif
fprintf(Stats.fstats,"%2.2f (%2.2fu + %2.2fs)\n",
Stats.Utime+Stats.Stime, Stats.Utime, Stats.Stime);
if (TotalRays != 0.)
fprintf(Stats.fstats,"Seconds / ray:\t\t\t%4.4f\n",
(Stats.Utime + Stats.Stime) / (Float)TotalRays);
if (Stats.HitRays != 0.)
fprintf(Stats.fstats,"Seconds / intersecting ray:\t%4.4f\n",
(Stats.Utime + Stats.Stime)/(Float)Stats.HitRays);
PrintMemoryStats(Stats.fstats);
}
static void
PrintGeomStats()
{
Geom *otmp;
unsigned long tests, hits, totaltests, totalhits;
char *name;
extern void GeomStats();
totaltests = totalhits = 0;
for (otmp = GeomRep; otmp; otmp = otmp->next) {
GeomStats(otmp, &tests, &hits);
if (tests <= 0)
continue;
name = GeomName(otmp);
fprintf(Stats.fstats,
"%c%s intersection tests:\t%lu (%lu hit, %f%%)\n",
toupper((int)name[0]), &name[1], tests, hits,
100.*(float)hits/(float)tests);
if (!IsAggregate(otmp)) {
totaltests += tests;
totalhits += hits;
}
}
fprintf(Stats.fstats,"Total prim. intersection tests:\t%lu",
totaltests);
if (totaltests == 0)
fprintf(Stats.fstats,"\n");
else
fprintf(Stats.fstats," (%lu hit, %f%%)\n", totalhits,
100.*(float)totalhits/(float)totaltests);
}
void
StatsAddRep(obj)
Geom *obj;
{
Geom *otmp;
for (otmp = GeomRep; otmp; otmp = otmp->next) {
if (otmp->methods->stats == obj->methods->stats)
return;
}
/*
* Stats method didn't match anything found so far. Add
* a copy of obj to head of GeomRep list.
*/
otmp = GeomCopy(obj);
otmp->next = GeomRep;
GeomRep = otmp;
}